import com.mysql.jdbc.jdbc2.optional.MysqlDataSource;

import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

//该类封装数据库的连接过程
//DBUtil可以想象成一个工具类,提供static方法,
//让其它代码直接调用
public class DBUtil {
    // 静态成员跟随类对象的. 类对象在整个进程中只有唯一一份
    // 静态成员相当于也是唯一的实例. (单例模式, 饿汉模式)
    private static DataSource dataSource = new MysqlDataSource();

    static {
        // 使用静态代码块, 针对 dataSource 进行初始化操作
        ((MysqlDataSource)dataSource).setUrl("jdbc:mysql://127.0.0.1:3306/wall?characterEncoding=utf8&useSSL=false");
        ((MysqlDataSource)dataSource).setUser("root");
        // 我这个机器的 mysql 没有密码, 直接写作 "" 即可
        ((MysqlDataSource)dataSource).setPassword("123456");
    }

    // 通过这个方法来建立连接
    public static Connection getConnection() throws SQLException {
        return dataSource.getConnection();
    }

    // 通过这个方法断开连接, 释放资源
    public static void close(Connection connection, PreparedStatement statement, ResultSet resultSet) {
        // 此处的三个 try catch 分开写更好, 避免前面的异常导致后面的代码不能执行.
        if (resultSet != null) {
            try {
                resultSet.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        if (statement != null) {
            try {
                statement.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        if (connection != null) {
            try {
                connection.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }
}
